package com.itheima.mapper;

import com.itheima.pojo.Clazz;
import com.itheima.pojo.Pagination;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.MapKey;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.util.List;
import java.util.Map;

@Mapper
public interface ClazzMapper {

    /**
     * 查询所有
     * @return
     */

    List<Clazz> list(Pagination clazzPage);

    /**
     *  删除
     */
    void delect(Integer id);




    /**
     * 添加
     * @param clazz
     */

    void add(Clazz clazz);

    /**
     * 根据id查询
     * @param id
     * @return
     */

    Clazz getById(Integer id);


    /**
     * 修改
     * @param clazz
     */
    void undeptas(Clazz clazz);

    /**
     * 查询所有
     * @return
     */
    List<Clazz> getList();



    /**
     * 统计各个部门的员工人数
     * @return
     */
    @MapKey("pos")//指定返回的map对象的key为pos
    List<Map<String, Object>> countClazzCountData();

    /**
     * 统计各个部门的学历人数
     * @return
     */
    @MapKey("name")//指定返回的map对象的key为pos
    List<Map> coutStudentDegreeData();


    /**
     * 检查班级下是否还有学生
     * @param clazzId
     * @return
     */
    @Select("select count(*) from student where clazz_id = #{clazzId}")//指定查询的SQL
    int countStudentByClazzId(Integer clazzId);
}
